

# Sunrise 3.0

# PLL/SD/EMAC Clock Structure

**Rev. 1.2 January 2021** 

### **Important Notice and Disclaimer**

Information in this document is provided solely to enable system and software implementers to use Horizon products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document.

The information in this document is subject to change without notice. Every effort has been made in the preparation of this document to ensure accuracy of the contents, but all statements, information, and recommendations in this document do not constitute a warranty of any kind, express or implied.

All statements, information and recommendations in this document are provided "AS IS". Horizon makes no warranty, representation or guarantee of any kind, express or implied, regarding the merchantability, fitness or suitability of its products for any particular purpose, and non-infringement of any third party intellectual property rights, nor does Horizon assume any liability arising out of the application or use of any product, and specifically disclaims any and all liability, including without limitation consequential or incidental damages.

Buyers and others who are developing systems that incorporate Horizon products (collectively, "Users") understand and agree that Users shall remain responsible for using independent analysis, evaluation and judgment in designing their applications and that Users have full and exclusive responsibility to assure the safety of Users' applications and compliance of their applications (and of all Horizon products used in or for Users' applications) with all applicable regulations, laws and other applicable requirements. "Typical" parameters that may be provided in Horizon datasheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals", must be validated for each User application by Users themselves.

User agrees to fully indemnify Horizon and its representatives against any claims, damages, costs, losses and/or liabilities arising out of User's unauthorized application of Horizon products and non-compliance with any terms of this notice. © 2018 Horizon Robotics. All rights reserved.

Horizon Robotics, Inc.

https://www.horizon.ai



# **Revision History**

This section tracks the significant documentation changes that occur from release-to-release. The following table lists the technical content changes for each revision.

| Revision | Date       | Description                                                                                                                                                                                                          |
|----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.0      | 2021-01-06 | Initial release.                                                                                                                                                                                                     |
| 1.1      | 2021-01-12 | <ul> <li>Updated the base address of each control register.</li> <li>Updated the bits information, default value and description of the DIV2_SEL bit filed in the EMAC Clock Control register.</li> </ul>            |
| 1.2      | 2021-01-14 | <ul> <li>Added Section 3 SD1 Clock<br/>Structure.</li> <li>Added Section 4 SD2 Clock<br/>Structure.</li> <li>Added Section 5 I2S0 Clock<br/>Structure.</li> <li>Added Section 6 I2S1 Clock<br/>Structure.</li> </ul> |



## **Contents**

| lm  | portant Notice and Disclaimer | 0   |
|-----|-------------------------------|-----|
| Rev | vision History                | i   |
| Со  | ntents                        | ii  |
| Fig | ures                          | iii |
| Tab | oles                          | iv  |
| 1   | PLL Frequency Configurations  | 1   |
| 2   | SD0 Clock Structure           | 3   |
| 3   | SD1 Clock Structure           | 4   |
| 4   | SD2 Clock Structure           | 5   |
| 5   | I2S0 Clock Structure          | 6   |
| 6   | I2S1 Clock Structure          | 7   |
| 7   | FMAC Clock Structure          | 8   |



# **Figures**

| Figure 2-1 SD0 Clock Structure  | 3 |
|---------------------------------|---|
| Figure 3-1 SD1 Clock Structure  | 4 |
| Figure 4-1 SD2 Clock Structure  | 5 |
| Figure 5-1 I2S0 Clock Structure | 6 |
| Figure 6-1 I2S1 Clock Structure | 7 |
| Figure 7-1 EMAC Clock Structure | 8 |



# **Tables**

| Table 1-1 PLL Frequency Configurations | 1 |
|----------------------------------------|---|
| Table 2-1 SD0 Clock Control Register   | 3 |
| Table 3-1 SD1 Clock Control Register   | 4 |
| Table 4-1 SD2 Clock Control Register   | 5 |
| Table 5-1 I2S0 Clock Control Register  | 6 |
| Table 6-1 I2S1 Clock Control Register  | 7 |
| Table 7-1 EMAC Clock Control Register  | 8 |



# 1 PLL Frequency Configurations

The PLL frequency configurations are as follows:

Fout = (Fref \* FBDIV) / (REFDIV \* POSTDIV1 \* POSTDIV2), where POSTDIV1 > POSTDIV2.

#### PLL Frequency Control Register (0xA100\_0000 + PLL\_offset)

**Table 1-1 PLL Frequency Configurations** 

| Register Name | PLL_offset | Bits    | Field Name | Default Value | PLL Output Freq. (MHz)  |
|---------------|------------|---------|------------|---------------|-------------------------|
| ARMPLL        | 0x0        | [26:24] | POSTDIV2   | 1             | Fout=24*100/1*2*1=1,200 |
|               |            | [22:20] | POSTDIV1   | 2             |                         |
|               |            | [17:12] | REFDIV     | 1             |                         |
|               |            | [11:0]  | FBDIV      | 100           | 0-                      |
| SYSPLL        | 0x10       | [26:24] | POSTDIV2   | 1             | Fout=24*125/1*2*1=1,500 |
|               |            | [22:20] | POSTDIV1   | 2             | .0/                     |
|               |            | [17:12] | REFDIV     | 1             | VO.                     |
|               |            | [11:0]  | FBDIV      | 1 0           | <b>&gt;</b>             |
| CNNPLL        | 0x20       | [26:24] | POSTDIV2   | 1             | Fout=24*250/3*2*1=1,000 |
|               |            | [22:20] | POSTDIV1   | 2             |                         |
|               |            | [17:12] | REFDIV     | 3             |                         |
|               |            | [11:0]  | FBDIV      | 250           |                         |
| DDRPLL        | 0x30       | [26:24] | POSTDIV2   | 1             | Fout=24*55/1*1*1=1,320  |
|               |            | [22:20] | POSTDIV1   | 1             |                         |
|               |            | [17:12] | REFDIV     | 1             |                         |
|               |            | [11:0]  | FBDIV      | 55            |                         |
| VIOPLL        | 0x40       | [26:24] | POSTDIV2   | 1             | Fout=24*64/1*1*1=1,632  |
|               | /./        | [22:20] | POSTDIV1   | 1             |                         |
|               |            | [17:12] | REFDIV     | 1             |                         |
|               |            | [11:0]  | FBDIV      | 68            |                         |
| PERIPHPLL     | 0x50       | [26:24] | POSTDIV2   | 1             | Fout=24*100/1*2*1=1,536 |
|               | 1.         | [22:20] | POSTDIV1   | 1             |                         |
|               |            | [17:12] | REFDIV     | 1             |                         |
|               |            | [11:0]  | FBDIV      | 64            |                         |
| VIOPLL2       | 0xB0       | [26:24] | POSTDIV2   | 1             | Fout=24*99/1*1*1=2,376  |
|               |            | [22:20] | POSTDIV1   | 1             |                         |
|               |            | [17:12] | REFDIV     | 1             |                         |



| Register Name | PLL_offset | Bits   | Field Name | Default Value | PLL Output Freq. (MHz) |
|---------------|------------|--------|------------|---------------|------------------------|
|               |            | [11:0] | FBDIV      | 99            |                        |



## 2 SD0 Clock Structure

The SD0 module clock structure is as shown in Figure 2-1.

Figure 2-1 SD0 Clock Structure



#### SD0 Clock Control Register (0xA100\_0000 + 0x320)

**Table 2-1 SD0 Clock Control Register** 

| Bits  | Field Name | Default Value | Description     |
|-------|------------|---------------|-----------------|
| [3:0] | DIV1_SEL   | 4'h0          | Divider select: |
|       |            |               | 4'h0: refclk/1  |
|       |            |               | 4'h1: refclk/2  |
|       |            |               | 🚫               |
|       |            |               | 4'h9: refclk/10 |
|       |            |               | , ) /           |
|       |            |               | 4'hE: refclk/15 |
|       |            | 0-            | 4'hF: refclk/16 |
| [7:4] | DIV2_SEL   | 4'h7          | Divider select: |
|       |            | -00.          | 4'h0: refclk/1  |
|       |            | 77.6          | 4'h1: refclk/2  |
|       |            | XXIX          |                 |
|       |            | X             | 4'h9: refclk/10 |
|       | ***        | 7             |                 |
|       | 1          |               | 4'hE: refclk/15 |
|       |            |               | 4'hF: refclk/16 |



## 3 SD1 Clock Structure

The SD1 module clock structure is as shown in Figure 3-1.

Figure 3-1 SD1 Clock Structure



#### SD1 Clock Control Register (0xA100\_0000 + 0x330)

**Table 3-1 SD1 Clock Control Register** 

| Bits  | Field Name | Default Value | Description     |
|-------|------------|---------------|-----------------|
| [3:0] | DIV1_SEL   | 4'h0          | Divider select: |
|       |            |               | 4'h0: refclk/1  |
|       |            |               | 4'h1: refclk/2  |
|       |            |               | 🚫               |
|       |            |               | 4'h9: refclk/10 |
|       |            |               | ,               |
|       |            |               | 4'hE: refclk/15 |
|       |            | 0-            | 4'hF: refclk/16 |
| [7:4] | DIV2_SEL   | 4'h7          | Divider select: |
|       |            | -00,          | 4'h0: refclk/1  |
|       |            | 77.75         | 4'h1: refclk/2  |
|       |            | XXIX'         |                 |
|       |            | X             | 4'h9: refclk/10 |
|       | ***/_      |               |                 |
|       |            |               | 4'hE: refclk/15 |
|       |            |               | 4'hF: refclk/16 |



## 4 SD2 Clock Structure

The SD2 module clock structure is as shown in Figure 4-1.

Figure 4-1 SD2 Clock Structure



#### SD2 Clock Control Register (0xA100\_0000 + 0x340)

**Table 4-1 SD2 Clock Control Register** 

| Bits  | Field Name | Default Value | Description     |
|-------|------------|---------------|-----------------|
| [3:0] | DIV1_SEL   | 4'h0          | Divider select: |
|       |            |               | 4'h0: refclk/1  |
|       |            |               | 4'h1: refclk/2  |
|       |            |               |                 |
|       |            |               | 4'h9: refclk/10 |
|       |            |               | ,               |
|       |            |               | 4'hE: refclk/15 |
|       |            | 0-            | 4'hF: refclk/16 |
| [7:4] | DIV2_SEL   | 4'h7          | Divider select: |
|       |            | -00,          | 4'h0: refclk/1  |
|       |            | 77.           | 4'h1: refclk/2  |
|       |            | XXIX'         |                 |
|       |            | X             | 4'h9: refclk/10 |
|       | ***/-      |               |                 |
|       |            |               | 4'hE: refclk/15 |
|       |            |               | 4'hF: refclk/16 |



## 5 I2SO Clock Structure

The I2SO module clock structure is as shown in Figure 5-1.

Figure 5-1 I2S0 Clock Structure



#### I2S0 Clock Control Register (0xA100\_0000 + 0x350)

**Table 5-1 I2S0 Clock Control Register** 

| Bits    | Field Name | Default Value | Description      |
|---------|------------|---------------|------------------|
| [4:0]   | DIV1_SEL   | 5'd24         | Divider select:  |
|         |            |               | 5'd0: refclk/1   |
|         |            |               | 5'd1: refclk/2   |
|         |            |               |                  |
|         |            |               | 5'd24: refclk/25 |
|         |            |               | ··· &            |
|         |            |               | 5'd30: refclk/31 |
|         |            |               | 5'h31: refclk/32 |
| [12:8]  | DIV2_SEL   | 5'd4          | Divider select:  |
|         |            | $\sim$ $\sim$ | 5'd0: refclk/1   |
|         |            | -00           | 5'd1: refclk/2   |
|         |            | 177           |                  |
|         |            | XX1           | 5'd4: refclk/5   |
|         |            | <             |                  |
|         | **//-      |               | 5'd30: refclk/31 |
|         | 1/2        |               | 5'h31: refclk/32 |
| [18:16] | DIV3_SEL   | 3'd3          | Divider select:  |
|         |            |               | 3'd0: refclk/1   |
|         | <i>(*)</i> |               | 3'd1: refclk/2   |
|         |            |               | 3'd2: refclk/3   |
| 1       |            |               | 3'd3: refclk/4   |
|         |            |               | 3'd4: refclk/5   |
|         |            |               | 3'd5: refclk/6   |
|         |            |               | 3'd6: refclk/7   |
|         |            |               | 3'd7: refclk/8   |



## 6 I2S1 Clock Structure

The I2S1 module clock structure is as shown in Figure 6-1.

Figure 6-1 I2S1 Clock Structure



#### I2S1 Clock Control Register (0xA100\_0000 + 0x360)

**Table 6-1 I2S1 Clock Control Register** 

| Bits    | Field Name | Default Value             | Description      |
|---------|------------|---------------------------|------------------|
| [4:0]   | DIV1_SEL   | 5'd24                     | Divider select:  |
|         |            |                           | 5'd0: refclk/1   |
|         |            |                           | 5'd1: refclk/2   |
|         |            |                           |                  |
|         |            |                           | 5'd24: refclk/25 |
|         |            |                           |                  |
|         |            |                           | 5'd30: refclk/31 |
|         |            |                           | 5'h31: refclk/32 |
| [12:8]  | DIV2_SEL   | 5'd4                      | Divider select:  |
|         |            | $\mathbf{I}$ $\mathbf{A}$ | 5'd0: refclk/1   |
|         |            | -00.                      | 5'd1: refclk/2   |
|         |            | XXV                       |                  |
|         |            | XX1X                      | 5'd4: refclk/5   |
|         |            | <×                        |                  |
|         | **/-       |                           | 5'd30: refclk/31 |
|         | 1/2        |                           | 5'h31: refclk/32 |
| [18:16] | DIV3_SEL   | 3'd3                      | Divider select:  |
|         |            |                           | 3'd0: refclk/1   |
| />      | 7          |                           | 3'd1: refclk/2   |
|         |            |                           | 3'd2: refclk/3   |
| / /     |            |                           | 3'd3: refclk/4   |
|         |            |                           | 3'd4: refclk/5   |
|         |            |                           | 3'd5: refclk/6   |
|         |            |                           | 3'd6: refclk/7   |
|         |            |                           | 3'd7: refclk/8   |



## **7 EMAC Clock Structure**

The EMAC module clock structure is as shown in Figure 7-1.

Figure 7-1 EMAC Clock Structure



#### EMAC Clock Control Register (0xA100\_0000 + 0x380)

**Table 7-1 EMAC Clock Control Register** 

| Bits   | Field name | Default Value | Description                      |
|--------|------------|---------------|----------------------------------|
| [4:0]  | DIV1_SEL   | 5'd11         | Divider select:                  |
|        |            |               | 5'd0: refclk/1                   |
|        |            |               | 5'd1: refclk/2                   |
|        |            |               |                                  |
|        |            |               | 5'd11: refclk/12(1500/12=125MHz) |
|        |            |               | , , , ,                          |
|        |            |               | 5'd29: refclk/30                 |
|        |            |               | 5'd30: refclk/31                 |
|        |            |               | 5'd31: refclk/32                 |
| [10:8] | DIV2_SEL   | 3'd0          | Divider select:                  |
|        |            | XX            | 3'd0: refclk/1                   |
|        |            | ×X1           | 3'd1: refclk/2                   |
|        |            | XX            | 3'd2: refclk/3                   |
|        | ***        |               | 3'd3: refclk/4                   |
|        |            |               | 3'd4: refclk/5                   |
|        |            |               | 3'd5: refclk/6                   |
|        |            |               | 3'd6: refclk/7                   |
| //     | RY'        |               | 3'd7: refclk/8                   |